Skip to main content
Version: v1

Getting started

Dependencies

To run the application locally you need to install the following dependencies:

  • Docker
  • yarn
  • make
    • Available in most Linux distributions.
    • Often also in MacOS systems but, if not, you can get it by installing the command line tools with xcode-select --install.
    • For Windows, you can install it via chocolatey.

Get Started

Monorepo

The RSD-as-a-Service project is a divided into different services included in the mono repo:

|-- authentication |-- backend-postgrest |-- data-migration |-- database |-- deployment |-- documentation |-- frontend |-- nginx |-- scrapers

Environment variables

The environment variables should be stored in a .env file, which is automatically loaded by docker compose. To validate loading of env variables use docker compose config. More info about the use of environment variables in docker compose is available at official documentation

  • copy the file .env.example to .env file at the root of the project
# from project root dir
cp .env.example .env
  • You need to modify the new .env file with the corresponding value secrets.
  • build local images
# from project root dir
docker compose build

Running locally

Run the command docker compose up.

# from project root dir
docker compose up

The application can be viewed at http://localhost

Logging in with admin rights

The default role assigned to a logged in user is rsd_user. To obtain the rsd_admin role, you need to update the RSD_ADMIN_EMAIL_LIST variable in .env.

Local accounts

::: danger Local accounts should only be used in development mode. :::

If you activated local login by adding LOCAL to RSD_AUTH_PROVIDERS, admin rights can be obtained by adding <name>@example.com to RSD_ADMIN_EMAIL_LIST, where <names> is the name entered when logging in. Here is an example:

RSD_AUTH_PROVIDERS=LOCAL
RSD_ADMIN_EMAIL_LIST=admin@example.com

If you now login as the user admin, you will be assigned the role rsd_admin.

Other IDPs

If you are using other IDPs, make sure to add the mail address that is being provided by the IDP. If you are using the SURFconext development instance, have a look at this list to obtain the email addresses that are provided for the test accounts.

Frontend with hot-module-replacement (HMR)

To run the frontend in the development mode with the hot-module-replacement (HMR) you should start an additional instance of the frontend which will be available at http://localhost:3000

# navigate to frontend folder
cd frontend
# install dependencies
yarn install
# start fe in dev mode
yarn dev

More information about the frontend setup is available in the frontend readme file.

Documentation site

The documentation site runs on GitHub Pages. Any changes inside this folder will trigger a GitHub action to deploy the changes automatically when merging a Pull Request to the main branch.

To run locally the documentation site, you need nodejs installed on your machine.

# navigate to frontend folder
cd documentation
# install dependencies
yarn install
# start fe in dev mode
yarn dev

All documentation files written in Markdown are placed inside the ./documentation/docs/ folder.

You can edit the navigation bar and the sidebar from the ./doumentation/docs/.vuepress/config.js file.

Any file markdown file added indie the docs folder will be available on built time.

Clear/remove data (reset)

To clear the database, if the database structure has changed or you need to run data migration again, run the command:

docker compose down --volumes

Tech Stack

image